package hot_100;

import java.util.ArrayList;
import java.util.List;

/**
 * @author: Darven
 * @createTime: 2025-09-27  17:03
 * @description: TODO
 */
public class P73 {
    public static void main(String[] args) {

    }

//    public void setZeroes(int[][] matrix) {
//        int m = matrix.length;
//        int n = matrix[0].length;
//
//        List<int[]> indexs = new ArrayList<>();
//
//        for (int i = 0; i < m; i++) {
//            for (int j = 0; j < n; j++) {
//                if (matrix[i][j] == 0) {
//                    indexs.add(new int[]{i, j});
//                }
//            }
//        }
//
//        // 刷新matrix  行
//        for (int[] index : indexs) {
//            int i = index[0];
//            int j = index[1];
//
//            for(int i1=0;i1<m;i1++){
//                matrix[i1][j]=0;
//            }
//
//            for(int i1=0;i1<n;i1++){
//                matrix[i][i1]=0;
//            }
//        }
//
//    }

    public void setZeroes(int[][] matrix) {
        int m = matrix.length;
        int n = matrix[0].length;

        // 使用原地标定,如果是0，0注意
        boolean row = false;
        boolean col = false;
        for (int i = 0; i < m; i++) {
            for (int j = 0; j < n; j++) {
                if (matrix[i][j] == 0) {
                    if (i == 0) {
                        row=true;
                    }
                    if (j == 0) {
                        col=true;
                    }
                    matrix[i][0] = 0;
                    matrix[0][j] = 0;
                }
            }
        }

        // 注意标志位是0，0的
        for (int i = 1; i < m; i++) {
            if (matrix[i][0] == 0) {
                for (int j = 1; j < n; j++) {
                    matrix[i][j] = 0;
                }
            }
        }

        for (int j = 1; j < n; j++) {
            if (matrix[0][j] == 0) {
                for (int i = 1; i < m; i++) {
                    matrix[i][j] = 0;
                }
            }
        }

        // 若原始第一行有0，将整个第一行置零
        if (row ) {
            for (int j = 0; j < n; j++) {
                matrix[0][j] = 0;
            }
        }

        // 若原始第一列有0，将整个第一列置零
        if (col ) {
            for (int i = 0; i < m; i++) {
                matrix[i][0] = 0;
            }
        }
    }
}
